<script>
//导入router  路由器
import { useRouter, useRoute } from "vue-router";

import { ref, reactive, toRefs, onMounted } from "vue";

import axios from "axios";

import { getSessionStorage, setSessionStorage } from "../common.js";

import Footer from '@/components/Footer.vue';

export default {

    setup() {
        //实例化router对象
        const router = useRouter();
        const route = useRoute();
        // 支付接口
        const alipayForm = ref()

        const state = reactive({
            user: getSessionStorage('user'),
            hpId: route.query.hpId,
            smId: route.query.smId,
            selectDay: route.query.selectDay,
            hospital: [],  //定义要遍历的数组  数据来自服务端
            setmeal: []
        });
        
         loadOrders();//页面渲染时调用该函数

        function loadOrders(){
            console.log(state.hpId)
            axios.post('/api/orders/getSmAndHp', {
                hpId: state.hpId,
                smId: state.smId
            }).then((response) => {

                console.log(state.user.userId);
                state.hospital = response.data.data.hospital;
                state.setmeal = response.data.data.setmeal;
            })
                .catch((error) => {
                    console.log(error);
                });
        }



        function toappointmentsuccess() {
            
            axios.post('/api/pay/alipay',{
                userId:state.user.userId,
                selectDay:state.selectDay,
                hospital:state.hospital,
                setmeal:state.setmeal
            }).then((response) => {

                console.log(response.data);
                
                // 将form表单字符串添加到<div>中
                alipayForm.value.innerHTML = response.data
                // console.log(alipayForm.value);
                //提交
                window.document.forms[0].submit()

            })
                .catch((error) => {
                    console.log(error);
                });
        }

        return {
            loadOrders,
            ...toRefs(state),
            toappointmentsuccess,
            alipayForm,
            
        }
    },
    components: {
        Footer
    }
};
</script>



<template>
    <!-- 总容器 -->
    <div class="wrapper">
        <header>
            <i class="fa fa-angle-left" onclick="history.go(-1)"></i>
            <p>确认您的订单</p>
            <div></div>
        </header>
        <div class="top-ban"></div>

        <section>
            <div class="title">
                <p>体检人信息</p>
            </div>
            <table>
                <tr>
                    <td>姓名:</td>
                    <td>{{ user.realName }}</td>
                </tr>
                <tr>
                    <td>证件号码:</td>
                    <td>{{ user.identityCard }}</td>
                </tr>
                <tr>
                    <td>出生日期:</td>
                    <!-- 获取 0~10  位 slice(0, 10)   -->
                    <td>{{ (user.birthday).slice(0, 10) }}</td>   
                </tr>
                <tr>
                    <td>手机号码:</td>
                    <td>{{ user.userId }}</td>
                </tr>
            </table>
            <div class="title">
                <p>体检日期</p>
            </div>
            <table>
                <tr>
                    <td>{{ selectDay }}</td>
                </tr>
            </table>
            <div class="title">
                <p>体检机构</p>
            </div>
            <table>
                <tr>
                    <td colspan="2">{{ hospital.name }}</td>
                </tr>
                <tr>
                    <td>营业时间:</td>
                    <td>{{ hospital.businessHours }}</td>
                </tr>
                <tr>
                    <td>采血截止:</td>
                    <td>{{ hospital.deadline }}</td>
                </tr>
                <tr>
                    <td>机构电话:</td>
                    <td>{{ hospital.telephone }}</td>
                </tr>
                <tr>
                    <td>机构地址:</td>
                    <td>{{ hospital.address }}</td>
                </tr>
            </table>
            <div class="title">
                <p>套餐类型</p>
            </div>
            <table>
                <tr>
                    <td>{{ setmeal.name }}</td>
                </tr>
            </table>
        </section>
        <div ref="alipayForm"></div>
        <div class="bottom-btn">
            <div class="first">实付款: <span>￥{{ setmeal.price }}</span></div>
            <div class="last" @click="toappointmentsuccess">确认支付</div>
        </div>

        <div class="bottom-ban"></div>
        <Footer></Footer>
    </div>
</template>



<style scoped>
/*********************** 总容器 ***********************/
.wrapper {
    width: 100%;
    height: 100%;
    background-color: #F9F9F9;
}

/*********************** header ***********************/
header {
    width: 100%;
    height: 15.7vw;
    background-color: #FFF;

    position: fixed;
    left: 0;
    top: 0;

    display: flex;
    align-items: center;
    justify-content: space-between;

    box-sizing: border-box;
    padding: 0 3.6vw;
}

header .fa {
    font-size: 8vw;
}

/*********************** footer ***********************/
footer {
    width: 100%;
    height: 14.2vw;
    box-sizing: border-box;
    border-top: solid 1px #E9E9E9;
    background-color: #FFF;

    position: fixed;
    left: 0;
    bottom: 0;
}

footer ul {
    width: 100%;
    height: 14.2vw;
    display: flex;
    align-items: center;
    justify-content: space-around;
}

footer ul li {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    font-size: 3vw;
    color: #999;

    user-select: none;
    cursor: pointer;
}

footer ul li .fa {
    font-size: 5vw;
}

/*********************** common样式 ***********************/
.top-ban {
    width: 100%;
    height: 15.7vw;
}

.bottom-ban {
    width: 100%;
    height: 26.2vw;
}

/*********************** section ***********************/
section {
    width: 86vw;
    margin: 0 auto;
}

section .title {
    width: 100%;
    height: 12vw;
    border-bottom: solid 1px #EEE;

    display: flex;
    align-items: center;
}

section .title p {
    height: 3.4vw;
    line-height: 3.4vw;
    font-size: 4.2vw;
    font-weight: 600;
    box-sizing: border-box;
    padding-left: 3vw;
    border-left: solid 2px #127A90;
}

section table {
    font-size: 3.6vw;
    color: #555;
    margin-top: 2vw;
}

section table tr {
    line-height: 8vw;
}

section table tr td:first-child {
    width: 22%;
}

/*********************** bottom-btn ***********************/
.bottom-btn {
    width: 100%;
    height: 12vw;
    background-color: #FFF;

    position: fixed;
    left: 0;
    bottom: 14.2vw;

    display: flex;
}

.bottom-btn .first {
    flex: 2;
    line-height: 12vw;
    font-size: 4.6vw;
    box-sizing: border-box;
    padding-left: 6vw;
}

.bottom-btn .first span {
    color: #F77B2D;
}

.bottom-btn .last {
    flex: 1;
    background-color: #117C94;
    line-height: 12vw;
    text-align: center;
    font-size: 5vw;
    color: #FFF;

    user-select: none;
    cursor: pointer;
}
</style>